home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
AmigActive 10
/
AACD 10.iso
/
AACD
/
Games
/
MAME
/
src
/
drivers
/
sega.c
< prev
next >
Wrap
C/C++ Source or Header
|
2000-04-04
|
49KB
|
1,449 lines
/***************************************************************************
4/25/99 - Tac-Scan sound call for coins now works. (Jim Hernandez)
2/5/98 - Added input ports support for Tac Scan. Bonus Ships now work.
Zektor now uses it's own input port section. (Jim Hernandez)
Sega Vector memory map (preliminary)
Most of the info here comes from the wiretap archive at:
http://www.spies.com/arcade/simulation/gameHardware/
* Sega G80 Vector Simulation
ROM Address Map
---------------
Eliminator Elim4Player Space Fury Zektor TAC/SCAN Star Trk
-----+-----------+-----------+-----------+-------+---------+---------+
0000 | 969 | 1390 | 969 | 1611 | 1711 | 1873 | CPU u25
-----+-----------+-----------+-----------+-------+---------+---------+
0800 | 1333 | 1347 | 960 | 1586 | 1670 | 1848 | ROM u1
-----+-----------+-----------+-----------+-------+---------+---------+
1000 | 1334 | 1348 | 961 | 1587 | 1671 | 1849 | ROM u2
-----+-----------+-----------+-----------+-------+---------+---------+
1800 | 1335 | 1349 | 962 | 1588 | 1672 | 1850 | ROM u3
-----+-----------+-----------+-----------+-------+---------+---------+
2000 | 1336 | 1350 | 963 | 1589 | 1673 | 1851 | ROM u4
-----+-----------+-----------+-----------+-------+---------+---------+
2800 | 1337 | 1351 | 964 | 1590 | 1674 | 1852 | ROM u5
-----+-----------+-----------+-----------+-------+---------+---------+
3000 | 1338 | 1352 | 965 | 1591 | 1675 | 1853 | ROM u6
-----+-----------+-----------+-----------+-------+---------+---------+
3800 | 1339 | 1353 | 966 | 1592 | 1676 | 1854 | ROM u7
-----+-----------+-----------+-----------+-------+---------+---------+
4000 | 1340 | 1354 | 967 | 1593 | 1677 | 1855 | ROM u8
-----+-----------+-----------+-----------+-------+---------+---------+
4800 | 1341 | 1355 | 968 | 1594 | 1678 | 1856 | ROM u9
-----+-----------+-----------+-----------+-------+---------+---------+
5000 | 1342 | 1356 | | 1595 | 1679 | 1857 | ROM u10
-----+-----------+-----------+-----------+-------+---------+---------+
5800 | 1343 | 1357 | | 1596 | 1680 | 1858 | ROM u11
-----+-----------+-----------+-----------+-------+---------+---------+
6000 | 1344 | 1358 | | 1597 | 1681 | 1859 | ROM u12
-----+-----------+-----------+-----------+-------+---------+---------+
6800 | 1345 | 1359 | | 1598 | 1682 | 1860 | ROM u13
-----+-----------+-----------+-----------+-------+---------+---------+
7000 | | 1360 | | 1599 | 1683 | 1861 | ROM u14
-----+-----------+-----------+-----------+-------+---------+---------+
7800 | | 1600 | 1684 | 1862 | ROM u15
-----+-----------+-----------+-----------+-------+---------+---------+
8000 | | 1601 | 1685 | 1863 | ROM u16
-----+-----------+-----------+-----------+-------+---------+---------+
8800 | | 1602 | 1686 | 1864 | ROM u17
-----+-----------+-----------+-----------+-------+---------+---------+
9000 | | 1603 | 1687 | 1865 | ROM u18
-----+-----------+-----------+-----------+-------+---------+---------+
9800 | | 1604 | 1688 | 1866 | ROM u19
-----+-----------+-----------+-----------+-------+---------+---------+
A000 | | 1605 | 1709 | 1867 | ROM u20
-----+-----------+-----------+-----------+-------+---------+---------+
A800 | | 1606 | 1710 | 1868 | ROM u21
-----+-----------+-----------+-----------+-------+---------+---------+
B000 | | 1869 | ROM u22
-----+-----------+-----------+-----------+-------+---------+---------+
B800 | | 1870 | ROM u23
-----+-----------+-----------+-----------+-------+---------+---------+
I/O ports:
read:
write:
These games all have dipswitches, but they are mapped in such a way as to make
using them with MAME extremely difficult. I might try to implement them in the
future.
SWITCH MAPPINGS
---------------
+------+------+------+------+------+------+------+------+
|SW1-8 |SW1-7 |SW1-6 |SW1-5 |SW1-4 |SW1-3 |SW1-2 |SW1-1 |
+------+------+------+------+------+------+------+------+
F8:08 |F9:08 |FA:08 |FB:08 |F8:04 |F9:04 FA:04 FB:04 Zektor &
| | | | | | Space Fury
| | | | | |
1 -|------|------|------|------|------|--------------- upright
0 -|------|------|------|------|------|--------------- cocktail
| | | | | |
| 1 -|------|------|------|------|--------------- voice
| 0 -|------|------|------|------|--------------- no voice
| | | | |
| 1 | 1 -|------|------|--------------- 5 ships
| 0 | 1 -|------|------|--------------- 4 ships
| 1 | 0 -|------|------|--------------- 3 ships
| 0 | 0 -|------|------|--------------- 2 ships
| | |
| 1 | 1 -|--------------- hardest
| 0 | 1 -|--------------- hard
1 = Open | 1 | 0 -|--------------- medium
0 = Closed | 0 | 0 -|--------------- easy
+------+------+------+------+------+------+------+------+
|SW2-8 |SW2-7 |SW2-6 |SW2-5 |SW2-4 |SW2-3 |SW2-2 |SW2-1 |
+------+------+------+------+------+------+------+------+
|F8:02 |F9:02 |FA:02 |FB:02 |F8:01 |F9:01 |FA:01 |FB:01 |
| | | | | | | | |
| 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 coin/ 1 play
+------+------+------+------+------+------+------+------+
Known problems:
1 The games seem to run too fast. This is most noticable
with the speech samples in Zektor - they don't match the mouth.
Slowing down the Z80 doesn't help and in fact hurts performance.
2 Cocktail mode isn't implemented.
Is 1) still valid?
***************************************************************************/
#include "driver.h"
#include "vidhrdw/vector.h"
extern unsigned char *sega_mem;
extern void sega_security(int chip);
WRITE_HANDLER( sega_w );
READ_HANDLER( sega_ports_r );
READ_HANDLER( sega_IN4_r );
READ_HANDLER( elim4_IN4_r );
int sega_interrupt(void);
READ_HANDLER( sega_mult_r );
WRITE_HANDLER( sega_mult1_w );
WRITE_HANDLER( sega_mult2_w );
WRITE_HANDLER( sega_switch_w );
/* Sound hardware prototypes */
int sega_sh_start (const struct MachineSound *msound);
READ_HANDLER( sega_sh_r );
WRITE_HANDLER( sega_sh_speech_w );
void sega_sh_update(void);
WRITE_HANDLER( elim1_sh_w );
WRITE_HANDLER( elim2_sh_w );
WRITE_HANDLER( spacfury1_sh_w );
WRITE_HANDLER( spacfury2_sh_w );
WRITE_HANDLER( zektor1_sh_w );
WRITE_HANDLER( zektor2_sh_w );
int tacscan_sh_start (const struct MachineSound *msound);
WRITE_HANDLER( tacscan_sh_w );
void tacscan_sh_update(void);
WRITE_HANDLER( startrek_sh_w );
/* Video hardware prototypes */
void sega_init_colors (unsigned char *palette, unsigned short *colortable,const unsigned char *color_prom);
int sega_vh_start (void);
void sega_vh_stop (void);
void sega_vh_screenrefresh(struct osd_bitmap *bitmap,int full_refresh);
static struct MemoryReadAddress readmem[] =
{
{ 0x0000, 0xbfff, MRA_ROM },
{ 0xc800, 0xcfff, MRA_RAM },
{ 0xe000, 0xefff, MRA_RAM },
{ 0xd000, 0xdfff, MRA_RAM }, /* sound ram */
{ -1 } /* end of table */
};
static struct MemoryWriteAddress writemem[] =
{
{ 0x0000, 0xffff, sega_w, &sega_mem },
{ 0xe000, 0xefff, MWA_RAM, &vectorram, &vectorram_size }, /* handled by the above, */
/* here only to initialize the pointer */
{ -1 }
};
static struct IOReadPort spacfury_readport[] =
{
{ 0x3f, 0x3f, sega_sh_r },
{ 0xbe, 0xbe, sega_mult_r },
{ 0xf8, 0xfb, sega_ports_r },
{ -1 } /* end of table */
};
static struct IOWritePort spacfury_writeport[] =
{
{ 0x38, 0x38, sega_sh_speech_w },
{ 0x3e, 0x3e, spacfury1_sh_w },
{ 0x3f, 0x3f, spacfury2_sh_w },
{ 0xbd, 0xbd, sega_mult1_w },
{ 0xbe, 0xbe, sega_mult2_w },
{ 0xf9, 0xf9, coin_counter_w }, /* 0x80 = enable, 0x00 = disable */
{ -1 } /* end of table */
};
static struct IOReadPort zektor_readport[] =
{
{ 0x3f, 0x3f, sega_sh_r },
{ 0xbe, 0xbe, sega_mult_r },
{ 0xf8, 0xfb, sega_ports_r },
{ 0xfc, 0xfc, sega_IN4_r },
{ -1 } /* end of table */
};
static struct IOWritePort zektor_writeport[] =
{
{ 0x38, 0x38, sega_sh_speech_w },
{ 0x3e, 0x3e, zektor1_sh_w },
{ 0x3f, 0x3f, zektor2_sh_w },
{ 0xbd, 0xbd, sega_mult1_w },
{ 0xbe, 0xbe, sega_mult2_w },
{ 0xf8, 0xf8, sega_switch_w },
{ 0xf9, 0xf9, coin_counter_w }, /* 0x80 = enable, 0x00 = disable */
{ -1 } /* end of table */
};
static struct IOWritePort tacscan_writeport[] =
{
{ 0x3f, 0x3f, tacscan_sh_w },
{ 0xbd, 0xbd, sega_mult1_w },
{ 0xbe, 0xbe, sega_mult2_w },
{ 0xf8, 0xf8, sega_switch_w },
{ 0xf9, 0xf9, coin_counter_w }, /* 0x80 = enable, 0x00 = disable */
{ -1 } /* end of table */
};
static struct IOReadPort elim2_readport[] =
{
{ 0x3f, 0x3f, sega_sh_r },
{ 0xbe, 0xbe, sega_mult_r },
{ 0xf8, 0xfb, sega_ports_r },
{ 0xfc, 0xfc, input_port_4_r },
{ -1 } /* end of table */
};
static struct IOReadPort elim4_readport[] =
{
{ 0x3f, 0x3f, sega_sh_r },
{ 0xbe, 0xbe, sega_mult_r },
{ 0xf8, 0xfb, sega_ports_r },
{ 0xfc, 0xfc, elim4_IN4_r },
{ -1 } /* end of table */
};
static struct IOWritePort elim_writeport[] =
{
{ 0x3e, 0x3e, elim1_sh_w },
{ 0x3f, 0x3f, elim2_sh_w },
{ 0xbd, 0xbd, sega_mult1_w },
{ 0xbe, 0xbe, sega_mult2_w },
{ 0xf8, 0xf8, sega_switch_w },
{ 0xf9, 0xf9, coin_counter_w }, /* 0x80 = enable, 0x00 = disable */
{ -1 } /* end of table */
};
static struct IOWritePort startrek_writeport[] =
{
{ 0x38, 0x38, sega_sh_speech_w },
{ 0x3f, 0x3f, startrek_sh_w },
{ 0xbd, 0xbd, sega_mult1_w },
{ 0xbe, 0xbe, sega_mult2_w },
{ 0xf8, 0xf8, sega_switch_w },
{ 0xf9, 0xf9, coin_counter_w }, /* 0x80 = enable, 0x00 = disable */
{ -1 } /* end of table */
};
/*************************************************************************
Input Ports
*************************************************************************/
/* This fake input port is used for DIP Switch 2
for all games except Eliminato 4 players */
#define COINAGE PORT_START \
PORT_DIPNAME( 0x0f, 0x0c, DEF_STR ( Coin_B ) ) \
PORT_DIPSETTING( 0x00, DEF_STR ( 4C_1C ) ) \
PORT_DIPSETTING( 0x08, DEF_STR ( 3C_1C ) ) \
PORT_DIPSETTING( 0x09, "2 Coins/1 Credit 5/3 6/4" ) \
PORT_DIPSETTING( 0x05, "2 Coins/1 Credit 4/3" ) \
PORT_DIPSETTING( 0x04, DEF_STR ( 2C_1C ) ) \
PORT_DIPSETTING( 0x0c, DEF_STR ( 1C_1C ) ) \
PORT_DIPSETTING( 0x0d, "1 Coin/1 Credit 5/6" ) \
PORT_DIPSETTING( 0x03, "1 Coin/1 Credit 4/5" ) \
PORT_DIPSETTING( 0x0b, "1 Coin/1 Credit 2/3" ) \
PORT_DIPSETTING( 0x02, DEF_STR ( 1C_2C ) ) \
PORT_DIPSETTING( 0x0f, "1 Coin/2 Credits 4/9" ) \
PORT_DIPSETTING( 0x07, "1 Coin/2 Credits 5/11" ) \
PORT_DIPSETTING( 0x0a, DEF_STR ( 1C_3C ) ) \
PORT_DIPSETTING( 0x06, DEF_STR ( 1C_4C ) ) \
PORT_DIPSETTING( 0x0e, DEF_STR ( 1C_5C ) ) \
PORT_DIPSETTING( 0x01, DEF_STR ( 1C_6C ) ) \
PORT_DIPNAME( 0xf0, 0xc0, DEF_STR ( Coin_A ) ) \
PORT_DIPSETTING( 0x00, DEF_STR ( 4C_1C ) ) \
PORT_DIPSETTING( 0x80, DEF_STR ( 3C_1C ) ) \
PORT_DIPSETTING( 0x90, "2 Coins/1 Credit 5/3 6/4" ) \
PORT_DIPSETTING( 0x50, "2 Coins/1 Credit 4/3" ) \
PORT_DIPSETTING( 0x40, DEF_STR ( 2C_1C ) ) \
PORT_DIPSETTING( 0xc0, DEF_STR ( 1C_1C ) ) \
PORT_DIPSETTING( 0xd0, "1 Coin/1 Credit 5/6" ) \
PORT_DIPSETTING( 0x30, "1 Coin/1 Credit 4/5" ) \
PORT_DIPSETTING( 0xb0, "1 Coin/1 Credit 2/3" ) \
PORT_DIPSETTING( 0x20, DEF_STR ( 1C_2C ) ) \
PORT_DIPSETTING( 0xf0, "1 Coin/2 Credits 4/9" ) \
PORT_DIPSETTING( 0x70, "1 Coin/2 Credits 5/11" ) \
PORT_DIPSETTING( 0xa0, DEF_STR ( 1C_3C ) ) \
PORT_DIPSETTING( 0x60, DEF_STR ( 1C_4C ) ) \
PORT_DIPSETTING( 0xe0, DEF_STR ( 1C_5C ) ) \
PORT_DIPSETTING( 0x10, DEF_STR ( 1C_6C ) )
INPUT_PORTS_START( spacfury )
PORT_START /* IN0 - port 0xf8 */
/* The next bit is referred to as the Service switch in the self test - it just adds a credit */
PORT_BIT_IMPULSE( 0x20, IP_ACTIVE_LOW, IPT_COIN3, 3 )
PORT_BIT_IMPULSE( 0x40, IP_ACTIVE_LOW, IPT_COIN2, 3 )
PORT_BIT_IMPULSE( 0x80, IP_ACTIVE_LOW, IPT_COIN1, 3 )
PORT_START /* IN1 - port 0xf9 */
PORT_BIT ( 0x10, IP_ACTIVE_LOW, IPT_START2 )
PORT_BIT ( 0x20, IP_ACTIVE_LOW, IPT_START1 )
PORT_BIT ( 0xc0, IP_ACTIVE_LOW, IPT_UNUSED )
PORT_START /* IN2 - port 0xfa */
PORT_BIT ( 0x10, IP_ACTIVE_LOW, IPT_JOYSTICK_RIGHT )
PORT_BIT ( 0x20, IP_ACTIVE_LOW, IPT_JOYSTICK_LEFT )
PORT_BIT ( 0xc0, IP_ACTIVE_LOW, IPT_UNUSED )
PORT_START /* IN3 - port 0xfb */
PORT_BIT ( 0x10, IP_ACTIVE_LOW, IPT_BUTTON2 )
PORT_BIT ( 0x20, IP_ACTIVE_LOW, IPT_BUTTON1 )
PORT_BIT ( 0xc0, IP_ACTIVE_LOW, IPT_UNUSED )
PORT_START /* IN4 - FAKE - lazy way to move the self-test fake input port to 5 */
PORT_BIT ( 0xff, IP_ACTIVE_LOW, IPT_UNUSED )
PORT_START /* IN5 - FAKE */
/* This fake input port is used to get the status of the F2 key, */
/* and activate the test mode, which is triggered by a NMI */
PORT_BITX(0x01, IP_ACTIVE_HIGH, IPT_SERVICE, DEF_STR( Service_Mode ), KEYCODE_F2, IP_JOY_NONE )
PORT_START /* FAKE */
/* This fake input port is used for DIP Switch 1 */
PORT_DIPNAME( 0x03, 0x01, DEF_STR ( Bonus_Life ) )
PORT_DIPSETTING( 0x00, "10000" )
PORT_DIPSETTING( 0x02, "20000" )
PORT_DIPSETTING( 0x01, "30000" )
PORT_DIPSETTING( 0x03, "40000" )
PORT_DIPNAME( 0x0c, 0x00, DEF_STR ( Difficulty ) )
PORT_DIPSETTING( 0x00, "Easy" )
PORT_DIPSETTING( 0x08, "Normal" )
PORT_DIPSETTING( 0x04, "Hard" )
PORT_DIPSETTING( 0x0c, "Very Hard" )
PORT_DIPNAME( 0x30, 0x30, DEF_STR ( Lives ) )
PORT_DIPSETTING( 0x00, "2" )
PORT_DIPSETTING( 0x20, "3" )
PORT_DIPSETTING( 0x10, "4" )
PORT_DIPSETTING( 0x30, "5" )
PORT_DIPNAME( 0x40, 0x00, DEF_STR ( Demo_Sounds) )
PORT_DIPSETTING( 0x40, DEF_STR ( Off ) )
PORT_DIPSETTING( 0x00, DEF_STR ( On ) )
PORT_DIPNAME( 0x80, 0x80, DEF_STR ( Cabinet ) )
PORT_DIPSETTING( 0x80, DEF_STR ( Upright ) )
PORT_DIPSETTING( 0x00, DEF_STR ( Cocktail ) )
COINAGE
INPUT_PORTS_END
INPUT_PORTS_START( zektor )
PORT_START /* IN0 - port 0xf8 */
/* The next bit is referred to as the Service switch in the self test - it just adds a credit */
PORT_BIT_IMPULSE( 0x20, IP_ACTIVE_LOW, IPT_COIN3, 3 )
PORT_BIT_IMPULSE( 0x40, IP_ACTIVE_LOW, IPT_COIN2, 3 )
PORT_BIT_IMPULSE( 0x80, IP_ACTIVE_LOW, IPT_COIN1, 3 )
PORT_START /* IN1 - port 0xf9 */
PORT_BIT ( 0xf0, IP_ACTIVE_LOW, IPT_UNUSED )
PORT_START /* IN2 - port 0xfa */
PORT_BIT ( 0xf0, IP_ACTIVE_LOW, IPT_UNUSED )
PORT_START /* IN3 - port 0xfb */
PORT_BIT ( 0xf0, IP_ACTIVE_LOW, IPT_UNUSED )
PORT_START /* IN4 - port 0xfc - read in machine/sega.c */
PORT_BIT ( 0x01, IP_ACTIVE_HIGH, IPT_START1 )
PORT_BIT ( 0x02, IP_ACTIVE_HIGH, IPT_START2 )
PORT_BIT ( 0x04, IP_ACTIVE_HIGH, IPT_BUTTON1 )
PORT_BIT ( 0x08, IP_ACTIVE_HIGH, IPT_BUTTON2 )
PORT_BIT ( 0xf0, IP_ACTIVE_HIGH, IPT_UNUSED )
PORT_START /* IN5 - FAKE */
/* This fake input port is used to get the status of the F2 key, */
/* and activate the test mode, which is triggered by a NMI */
PORT_BITX(0x01, IP_ACTIVE_HIGH, IPT_SERVICE, DEF_STR( Service_Mode ), KEYCODE_F2, IP_JOY_NONE )
PORT_START /* FAKE */
/* This fake input port is used for DIP Switch 1 */
PORT_DIPNAME( 0x03, 0x01, DEF_STR ( Bonus_Life ) )
PORT_DIPSETTING( 0x03, "10000" )
PORT_DIPSETTING( 0x01, "20000" )
PORT_DIPSETTING( 0x02, "30000" )
PORT_DIPSETTING( 0x00, "None" )
PORT_DIPNAME( 0x0c, 0x00, DEF_STR ( Difficulty ) )
PORT_DIPSETTING( 0x00, "Easy" )
PORT_DIPSETTING( 0x08, "Normal" )
PORT_DIPSETTING( 0x04, "Hard" )
PORT_DIPSETTING( 0x0c, "Very Hard" )
PORT_DIPNAME( 0x30, 0x30, DEF_STR ( Lives ) )
PORT_DIPSETTING( 0x00, "2" )
PORT_DIPSETTING( 0x20, "3" )
PORT_DIPSETTING( 0x10, "4" )
PORT_DIPSETTING( 0x30, "5" )
PORT_DIPNAME( 0x40, 0x00, DEF_STR ( Demo_Sounds ) )
PORT_DIPSETTING( 0x40, DEF_STR ( Off ) )
PORT_DIPSETTING( 0x00, DEF_STR ( On ) )
PORT_DIPNAME( 0x80, 0x80, DEF_STR ( Cabinet ) )
PORT_DIPSETTING( 0x80, DEF_STR ( Upright ) )
PORT_DIPSETTING( 0x00, DEF_STR ( Cocktail ) )
COINAGE
PORT_START /* IN8 - FAKE port for the dial */
PORT_ANALOG( 0xff, 0x00, IPT_DIAL | IPF_CENTER, 100, 10, 0, 0 )
INPUT_PORTS_END
INPUT_PORTS_START( startrek )
PORT_START /* IN0 - port 0xf8 */
/* The next bit is referred to as the Service switch in the self test - it just adds a credit */
PORT_BIT_IMPULSE( 0x20, IP_ACTIVE_LOW, IPT_COIN3, 3 )
PORT_BIT_IMPULSE( 0x40, IP_ACTIVE_LOW, IPT_COIN2, 3 )
PORT_BIT_IMPULSE( 0x80, IP_ACTIVE_LOW, IPT_COIN1, 3 )
PORT_START /* IN1 - port 0xf9 */
PORT_BIT ( 0xf0, IP_ACTIVE_LOW, IPT_UNUSED )
PORT_START /* IN2 - port 0xfa */
PORT_BIT ( 0xf0, IP_ACTIVE_LOW, IPT_UNUSED )
PORT_START /* IN3 - port 0xfb */
PORT_BIT ( 0xf0, IP_ACTIVE_LOW, IPT_UNUSED )
PORT_START /* IN4 - port 0xfc - read in machine/sega.c */
PORT_BIT ( 0x01, IP_ACTIVE_HIGH, IPT_START1 )
PORT_BIT ( 0x02, IP_ACTIVE_HIGH, IPT_START2 )
PORT_BIT ( 0x04, IP_ACTIVE_HIGH, IPT_BUTTON2 )
PORT_BIT ( 0x08, IP_ACTIVE_HIGH, IPT_BUTTON1 )
PORT_BIT ( 0x10, IP_ACTIVE_HIGH, IPT_BUTTON3 )
PORT_BIT ( 0x20, IP_ACTIVE_HIGH, IPT_BUTTON4 )
PORT_BIT ( 0xc0, IP_ACTIVE_HIGH, IPT_UNUSED )
PORT_START /* IN5 - FAKE */
/* This fake input port is used to get the status of the F2 key, */
/* and activate the test mode, which is triggered by a NMI */
PORT_BITX(0x01, IP_ACTIVE_HIGH, IPT_SERVICE, DEF_STR( Service_Mode ), KEYCODE_F2, IP_JOY_NONE )
PORT_START /* FAKE */
/* This fake input port is used for DIP Switch 1 */
PORT_DIPNAME( 0x03, 0x01, DEF_STR ( Bonus_Life ) )
PORT_DIPSETTING( 0x00, "10000" )
PORT_DIPSETTING( 0x02, "20000" )
PORT_DIPSETTING( 0x01, "30000" )
PORT_DIPSETTING( 0x03, "40000" )
PORT_DIPNAME( 0x0c, 0x00, DEF_STR ( Difficulty ) )
PORT_DIPSETTING( 0x00, "Easy" )
PORT_DIPSETTING( 0x08, "Medium" )
PORT_DIPSETTING( 0x04, "Hard" )
PORT_DIPSETTING( 0x0c, "Tournament" )
PORT_DIPNAME( 0x30, 0x30, "Photon Torpedoes" )
PORT_DIPSETTING( 0x00, "1" )
PORT_DIPSETTING( 0x20, "2" )
PORT_DIPSETTING( 0x10, "3" )
PORT_DIPSETTING( 0x30, "4" )
PORT_DIPNAME( 0x40, 0x00, "Demo Sounds?" )
PORT_DIPSETTING( 0x40, DEF_STR ( Off ) )
PORT_DIPSETTING( 0x00, DEF_STR ( On ) )
PORT_DIPNAME( 0x80, 0x80, DEF_STR ( Cabinet ) )
PORT_DIPSETTING( 0x80, DEF_STR ( Upright ) )
PORT_DIPSETTING( 0x00, DEF_STR ( Cocktail ) )
COINAGE
PORT_START /* IN8 - dummy port for the dial */
PORT_ANALOG( 0xff, 0x00, IPT_DIAL | IPF_CENTER, 100, 10, 0, 0 )
INPUT_PORTS_END
INPUT_PORTS_START( tacscan )
PORT_START /* IN0 - port 0xf8 */
/* The next bit is referred to as the Service switch in the self test - it just adds a credit */
PORT_BIT_IMPULSE( 0x20, IP_ACTIVE_LOW, IPT_COIN3, 3 )
PORT_BIT_IMPULSE( 0x40, IP_ACTIVE_LOW, IPT_COIN2, 3 )
PORT_BIT_IMPULSE( 0x80, IP_ACTIVE_LOW, IPT_COIN1, 3 )
PORT_START /* IN1 - port 0xf9 */
PORT_BIT ( 0xf0, IP_ACTIVE_LOW, IPT_UNUSED )
PORT_START /* IN2 - port 0xfa */
PORT_BIT ( 0xf0, IP_ACTIVE_LOW, IPT_UNUSED )
PORT_START /* IN3 - port 0xfb */
PORT_BIT ( 0xf0, IP_ACTIVE_LOW, IPT_UNUSED )
PORT_START /* IN4 - port 0xfc - read in machine/sega.c */
PORT_BIT ( 0x01, IP_ACTIVE_HIGH, IPT_START1 )
PORT_BIT ( 0x02, IP_ACTIVE_HIGH, IPT_START2 )
PORT_BIT ( 0x04, IP_ACTIVE_HIGH, IPT_BUTTON1 )
PORT_BIT ( 0x08, IP_ACTIVE_HIGH, IPT_BUTTON2 )
PORT_BIT ( 0xf0, IP_ACTIVE_HIGH, IPT_UNUSED )
PORT_START /* IN5 - FAKE */
/* This fake input port is used to get the status of the F2 key, */
/* and activate the test mode, which is triggered by a NMI */
PORT_BITX(0x01, IP_ACTIVE_HIGH, IPT_SERVICE, DEF_STR( Service_Mode ), KEYCODE_F2, IP_JOY_NONE )
PORT_START /* FAKE */
/* This fake input port is used for DIP Switch 1 */
PORT_DIPNAME( 0x03, 0x01, DEF_STR ( Bonus_Life ) )
PORT_DIPSETTING( 0x03, "10000" )
PORT_DIPSETTING( 0x01, "20000" )
PORT_DIPSETTING( 0x02, "30000" )
PORT_DIPSETTING( 0x00, "None" )
PORT_DIPNAME( 0x0c, 0x00, DEF_STR ( Difficulty ) )
PORT_DIPSETTING( 0x00, "Easy" )
PORT_DIPSETTING( 0x08, "Normal" )
PORT_DIPSETTING( 0x04, "Hard" )
PORT_DIPSETTING( 0x0c, "Very Hard" )
PORT_DIPNAME( 0x30, 0x30, "Number of Ships" )
PORT_DIPSETTING( 0x00, "2" )
PORT_DIPSETTING( 0x20, "4" )
PORT_DIPSETTING( 0x10, "6" )
PORT_DIPSETTING( 0x30, "8" )
PORT_DIPNAME( 0x40, 0x00, "Demo Sounds?" )
PORT_DIPSETTING( 0x40, DEF_STR ( Off ) )
PORT_DIPSETTING( 0x00, DEF_STR ( On ) )
PORT_DIPNAME( 0x80, 0x80, DEF_STR ( Cabinet ) )
PORT_DIPSETTING( 0x80, DEF_STR ( Upright ) )
PORT_DIPSETTING( 0x00, DEF_STR ( Cocktail ) )
COINAGE
PORT_START /* IN8 - FAKE port for the dial */
PORT_ANALOG( 0xff, 0x00, IPT_DIAL | IPF_CENTER, 100, 10, 0, 0 )
INPUT_PORTS_END
INPUT_PORTS_START( elim2 )
PORT_START /* IN0 - port 0xf8 */
/* The next bit is referred to as the Service switch in the self test - it just adds a credit */
PORT_BIT_IMPULSE( 0x20, IP_ACTIVE_LOW, IPT_COIN3, 3 )
PORT_BIT_IMPULSE( 0x40, IP_ACTIVE_LOW, IPT_COIN2, 3 )
PORT_BIT_IMPULSE( 0x80, IP_ACTIVE_LOW, IPT_COIN1, 3 )
PORT_START /* IN1 - port 0xf9 */
PORT_BIT ( 0x10, IP_ACTIVE_LOW, IPT_START2 )
PORT_BIT ( 0x20, IP_ACTIVE_LOW, IPT_START1 )
PORT_BIT ( 0xc0, IP_ACTIVE_LOW, IPT_UNUSED )
PORT_START /* IN2 - port 0xfa */
PORT_BIT ( 0x10, IP_ACTIVE_LOW, IPT_BUTTON2 )
PORT_BIT ( 0x20, IP_ACTIVE_LOW, IPT_JOYSTICK_RIGHT )
PORT_BIT ( 0x40, IP_ACTIVE_LOW, IPT_JOYSTICK_LEFT )
PORT_BIT ( 0x80, IP_ACTIVE_LOW, IPT_UNUSED )
PORT_START /* IN3 - port 0xfb */
PORT_BIT ( 0x10, IP_ACTIVE_LOW, IPT_JOYSTICK_LEFT | IPF_PLAYER2 )
PORT_BIT ( 0x20, IP_ACTIVE_LOW, IPT_BUTTON1 )
PORT_BIT ( 0xc0, IP_ACTIVE_LOW, IPT_UNUSED )
PORT_START /* IN4 - port 0xfc - read in machine/sega.c */
PORT_BIT ( 0x01, IP_ACTIVE_HIGH, IPT_BUTTON1 | IPF_PLAYER2 )
PORT_BIT ( 0x02, IP_ACTIVE_HIGH, IPT_BUTTON2 | IPF_PLAYER2 )
PORT_BIT ( 0x04, IP_ACTIVE_HIGH, IPT_JOYSTICK_RIGHT | IPF_PLAYER2 )
PORT_BIT ( 0xf8, IP_ACTIVE_HIGH, IPT_UNUSED )
PORT_START /* IN5 - FAKE */
/* This fake input port is used to get the status of the F2 key, */
/* and activate the test mode, which is triggered by a NMI */
PORT_BITX(0x01, IP_ACTIVE_HIGH, IPT_SERVICE, DEF_STR( Service_Mode ), KEYCODE_F2, IP_JOY_NONE )
PORT_START /* FAKE */
/* This fake input port is used for DIP Switch 1 */
PORT_DIPNAME( 0x03, 0x02, DEF_STR ( Bonus_Life ) )
PORT_DIPSETTING( 0x01, "10000" )
PORT_DIPSETTING( 0x02, "20000" )
PORT_DIPSETTING( 0x00, "30000" )
PORT_DIPSETTING( 0x03, "None" )
PORT_DIPNAME( 0x0c, 0x00, DEF_STR ( Difficulty ) )
PORT_DIPSETTING( 0x00, "Easy" )
PORT_DIPSETTING( 0x08, "Normal" )
PORT_DIPSETTING( 0x04, "Hard" )
PORT_DIPSETTING( 0x0c, "Very Hard" )
PORT_DIPNAME( 0x30, 0x20, DEF_STR ( Lives ) )
PORT_DIPSETTING( 0x20, "3" )
PORT_DIPSETTING( 0x10, "4" )
PORT_DIPSETTING( 0x00, "5" )
/* 0x30 gives 5 Lives */
PORT_DIPNAME( 0x80, 0x80, DEF_STR ( Cabinet ) )
PORT_DIPSETTING( 0x80, DEF_STR ( Upright ) )
PORT_DIPSETTING( 0x00, DEF_STR ( Cocktail ) )
COINAGE
INPUT_PORTS_END
INPUT_PORTS_START( elim4 )
PORT_START /* IN0 - port 0xf8 */
PORT_BIT ( 0x10, IP_ACTIVE_LOW, IPT_BUTTON1 )
/* The next bit is referred to as the Service switch in the self test - it just adds a credit */
PORT_BIT_IMPULSE( 0x20, IP_ACTIVE_LOW, IPT_COIN1, 3 )
PORT_BIT_IMPULSE( 0x40, IP_ACTIVE_LOW, IPT_COIN2, 3 )
PORT_BIT_IMPULSE( 0x80, IP_ACTIVE_LOW, IPT_COIN3, 3 )
PORT_START /* IN1 - port 0xf9 */
PORT_BIT ( 0x10, IP_ACTIVE_LOW, IPT_BUTTON2 )
PORT_BIT ( 0x20, IP_ACTIVE_LOW, IPT_BUTTON2 | IPF_PLAYER2 )
PORT_BIT ( 0xc0, IP_ACTIVE_LOW, IPT_UNUSED )
PORT_START /* IN2 - port 0xfa */
PORT_BIT ( 0x10, IP_ACTIVE_LOW, IPT_JOYSTICK_RIGHT )
PORT_BIT ( 0x20, IP_ACTIVE_LOW, IPT_JOYSTICK_RIGHT | IPF_PLAYER2 )
PORT_BIT ( 0x40, IP_ACTIVE_LOW, IPT_BUTTON1 | IPF_PLAYER2 )
PORT_BIT ( 0x80, IP_ACTIVE_LOW, IPT_UNUSED )
PORT_START /* IN3 - port 0xfb */
PORT_BIT ( 0x10, IP_ACTIVE_LOW, IPT_JOYSTICK_LEFT )
PORT_BIT ( 0x20, IP_ACTIVE_LOW, IPT_JOYSTICK_LEFT | IPF_PLAYER2 )
PORT_BIT ( 0xc0, IP_ACTIVE_LOW, IPT_UNUSED )
PORT_START /* IN4 - port 0xfc - read in machine/sega.c */
PORT_BIT ( 0x01, IP_ACTIVE_HIGH, IPT_BUTTON1 | IPF_PLAYER3 )
PORT_BIT ( 0x02, IP_ACTIVE_HIGH, IPT_BUTTON2 | IPF_PLAYER3 )
PORT_BIT ( 0x04, IP_ACTIVE_HIGH, IPT_JOYSTICK_LEFT | IPF_PLAYER3 )
PORT_BIT ( 0x08, IP_ACTIVE_HIGH, IPT_JOYSTICK_RIGHT | IPF_PLAYER3 )
PORT_BIT ( 0x10, IP_ACTIVE_HIGH, IPT_BUTTON1 | IPF_PLAYER4 )
PORT_BIT ( 0x20, IP_ACTIVE_HIGH, IPT_BUTTON2 | IPF_PLAYER4 )
PORT_BIT ( 0x40, IP_ACTIVE_HIGH, IPT_JOYSTICK_LEFT | IPF_PLAYER4 )
PORT_BIT ( 0x80, IP_ACTIVE_HIGH, IPT_JOYSTICK_RIGHT | IPF_PLAYER4 )
PORT_START /* IN5 - FAKE */
/* This fake input port is used to get the status of the F2 key, */
/* and activate the test mode, which is triggered by a NMI */
PORT_BITX(0x01, IP_ACTIVE_HIGH, IPT_SERVICE, DEF_STR( Service_Mode ), KEYCODE_F2, IP_JOY_NONE )
PORT_START /* FAKE */
/* This fake input port is used for DIP Switch 1 */
PORT_DIPNAME( 0x03, 0x02, DEF_STR ( Bonus_Life ) )
PORT_DIPSETTING( 0x01, "10000" )
PORT_DIPSETTING( 0x02, "20000" )
PORT_DIPSETTING( 0x00, "30000" )
PORT_DIPSETTING( 0x03, "None" )
PORT_DIPNAME( 0x0c, 0x00, DEF_STR ( Difficulty ) )
PORT_DIPSETTING( 0x00, "Easy" )
PORT_DIPSETTING( 0x08, "Normal" )
PORT_DIPSETTING( 0x04, "Hard" )
PORT_DIPSETTING( 0x0c, "Very Hard" )
PORT_DIPNAME( 0x30, 0x30, DEF_STR ( Lives ) )
PORT_DIPSETTING( 0x20, "3" )
PORT_DIPSETTING( 0x10, "4" )
PORT_DIPSETTING( 0x00, "5" )
/* 0x30 gives 5 Lives */
PORT_DIPNAME( 0x80, 0x80, DEF_STR ( Cabinet ) )
PORT_DIPSETTING( 0x80, DEF_STR ( Upright ) )
PORT_DIPSETTING( 0x00, DEF_STR ( Cocktail ) )
PORT_START /* That is the coinage port in all the other games */
PORT_BIT ( 0xff, IP_ACTIVE_LOW, IPT_UNKNOWN )
PORT_START /* IN8 - FAKE - port 0xfc - read in machine/sega.c */
PORT_BIT_IMPULSE( 0x01, IP_ACTIVE_HIGH, IPT_COIN1, 3 )
PORT_BIT_IMPULSE( 0x02, IP_ACTIVE_HIGH, IPT_COIN2, 3 )
PORT_BIT_IMPULSE( 0x04, IP_ACTIVE_HIGH, IPT_COIN3, 3 )
PORT_BIT_IMPULSE( 0x08, IP_ACTIVE_HIGH, IPT_COIN4, 3 )
PORT_BIT ( 0xf0, IP_ACTIVE_HIGH, IPT_UNUSED )
INPUT_PORTS_END
/***************************************************************************
Security Chips
***************************************************************************/
void init_spacfury(void)
{
/* This game uses the 315-0064 security chip */
sega_security(64);
}
void init_zektor(void)
{
/* This game uses the 315-0082 security chip */
sega_security(82);
}
void init_elim2(void)
{
/* This game uses the 315-0070 security chip */
sega_security(70);
}
void init_elim4(void)
{
/* This game uses the 315-0076 security chip */
sega_security(76);
}
void init_startrek(void)
{
/* This game uses the 315-0064 security chip */
sega_security(64);
}
void init_tacscan(void)
{
/* This game uses the 315-0076 security chip */
sega_security(76);
}
/***************************************************************************
Game driver(s)
***************************************************************************/
static const char *spacfury_sample_names[] =
{
"*spacfury",
/* Speech samples */
"sf01.wav",
"sf02.wav",
"sf03.wav",
"sf04.wav",
"sf05.wav",
"sf06.wav",
"sf07.wav",
"sf08.wav",
"sf09.wav",
"sf0a.wav",
"sf0b.wav",
"sf0c.wav",
"sf0d.wav",
"sf0e.wav",
"sf0f.wav",
"sf10.wav",
"sf11.wav",
"sf12.wav",
"sf13.wav",
"sf14.wav",
"sf15.wav",
/* Sound samples */
"sfury1.wav",
"sfury2.wav",
"sfury3.wav",
"sfury4.wav",
"sfury5.wav",
"sfury6.wav",
"sfury7.wav",
"sfury8.wav",
"sfury9.wav",
"sfury10.wav",
0 /* end of array */
};
static struct Samplesinterface spacfury_samples_interface =
{
9, /* 9 channels */
25, /* volume */
spacfury_sample_names
};
static struct CustomSound_interface sega_custom_interface =
{
sega_sh_start,
0,
sega_sh_update
};
static struct MachineDriver machine_driver_spacfury =
{
/* basic machine hardware */
{
{
CPU_Z80,
3867120, /* 3.86712 Mhz */
readmem, writemem, spacfury_readport, spacfury_writeport,
0, 0, /* no vblank interrupt */
sega_interrupt, 40 /* 40 Hz */
}
},
40, 0, /* frames per second, vblank duration (vector game, so no vblank) */
1, /* single CPU, no need for interleaving */
0,
/* video hardware */
400, 300, { 512, 1536, 552, 1464 },
0,
256,256,
sega_init_colors,
VIDEO_TYPE_VECTOR,
0,
sega_vh_start,
sega_vh_stop,
sega_vh_screenrefresh,
/* sound hardware */
0,0,0,0,
{
{
SOUND_SAMPLES,
&spacfury_samples_interface
},
{
SOUND_CUSTOM, /* actually plays the samples */
&sega_custom_interface
}
}
};
/***************************************************************************
Game driver(s)
***************************************************************************/
static const char *zektor_sample_names[] =
{
"*zektor",
"zk01.wav", /* 1 */
"zk02.wav",
"zk03.wav",
"zk04.wav",
"zk05.wav",
"zk06.wav",
"zk07.wav",
"zk08.wav",
"zk09.wav",
"zk0a.wav",
"zk0b.wav",
"zk0c.wav",
"zk0d.wav",
"zk0e.wav",
"zk0f.wav",
"zk10.wav",
"zk11.wav",
"zk12.wav",
"zk13.wav",
"elim1.wav", /* 19 fireball */
"elim2.wav", /* 20 bounce */
"elim3.wav", /* 21 Skitter */
"elim4.wav", /* 22 Eliminator */
"elim5.wav", /* 23 Electron */
"elim6.wav", /* 24 fire */
"elim7.wav", /* 25 thrust */
"elim8.wav", /* 26 Electron */
"elim9.wav", /* 27 small explosion */
"elim10.wav", /* 28 med explosion */
"elim11.wav", /* 29 big explosion */
/* Missing Zizzer */
/* Missing City fly by */
/* Missing Rotation Rings */
0 /* end of array */
};
static struct Samplesinterface zektor_samples_interface =
{
12, /* only speech for now */
25, /* volume */
zektor_sample_names
};
static struct MachineDriver machine_driver_zektor =
{
/* basic machine hardware */
{
{
CPU_Z80,
3867120, /* 3.86712 Mhz */
readmem,writemem,zektor_readport,zektor_writeport,
0, 0, /* no vblank interrupt */
sega_interrupt, 40 /* 40 Hz */
}
},
40, 0, /* frames per second, vblank duration (vector game, so no vblank) */
1, /* single CPU, no need for interleaving */
0,
/* video hardware */
400, 300, { 512, 1536, 624, 1432 },
0,
256,256,
sega_init_colors,
VIDEO_TYPE_VECTOR,
0,
sega_vh_start,
sega_vh_stop,
sega_vh_screenrefresh,
/* sound hardware */
0,0,0,0,
{
{
SOUND_SAMPLES,
&zektor_samples_interface
},
{
SOUND_CUSTOM, /* actually plays the samples */
&sega_custom_interface
}
}
};
/***************************************************************************
Game driver(s)
***************************************************************************/
static const char *tacscan_sample_names[] =
{
"*tacscan",
/* Player ship thrust sounds */
"01.wav",
"02.wav",
"03.wav",
"plaser.wav",
"pexpl.wav",
"pship.wav",
"tunnelh.wav",
"sthrust.wav",
"slaser.wav",
"sexpl.wav",
"eshot.wav",
"eexpl.wav",
"tunnelw.wav",
"flight1.wav",
"flight2.wav",
"flight3.wav",
"flight4.wav",
"flight5.wav",
"formatn.wav",
"warp.wav",
"credit.wav",
"1up.wav",
0 /* end of array */
};
static struct Samplesinterface tacscan_samples_interface =
{
12, /* 12 channels */
25, /* volume */
tacscan_sample_names
};
static struct CustomSound_interface tacscan_custom_interface =
{
tacscan_sh_start,
0,
tacscan_sh_update
};
static struct MachineDriver machine_driver_tacscan =
{
/* basic machine hardware */
{
{
CPU_Z80,
3867120, /* 3.86712 Mhz */
readmem,writemem,zektor_readport,tacscan_writeport,
0, 0, /* no vblank interrupt */
sega_interrupt, 40 /* 40 Hz */
}
},
40, 0, /* frames per second, vblank duration (vector game, so no vblank) */
1, /* single CPU, no need for interleaving */
0,
/* video hardware */
400, 300, { 496, 1552, 592, 1456 },
0,
256,256,
sega_init_colors,
VIDEO_TYPE_VECTOR,
0,
sega_vh_start,
sega_vh_stop,
sega_vh_screenrefresh,
/* sound hardware */
0,0,0,0,
{
{
SOUND_SAMPLES,
&tacscan_samples_interface
},
{
SOUND_CUSTOM, /* actually plays the samples */
&tacscan_custom_interface
}
}
};
/***************************************************************************
Game driver(s)
***************************************************************************/
/* Eliminator sound samples (all versions) */
static const char *elim_sample_names[] =
{
"*elim2",
"elim1.wav",
"elim2.wav",
"elim3.wav",
"elim4.wav",
"elim5.wav",
"elim6.wav",
"elim7.wav",
"elim8.wav",
"elim9.wav",
"elim10.wav",
"elim11.wav",
"elim12.wav",
0 /* end of array */
};
static struct Samplesinterface elim2_samples_interface =
{
8, /* 8 channels */
25, /* volume */
elim_sample_names
};
static struct MachineDriver machine_driver_elim2 =
{
/* basic machine hardware */
{
{
CPU_Z80,
3867120, /* 3.86712 Mhz */
readmem,writemem,elim2_readport,elim_writeport,
0, 0, /* no vblank interrupt */
sega_interrupt, 40 /* 40 Hz */
}
},
40, 0, /* frames per second, vblank duration (vector game, so no vblank) */
1, /* single CPU, no need for interleaving */
0,
/* video hardware */
400, 300, { 512, 1536, 600, 1440 },
0,
256,256,
sega_init_colors,
VIDEO_TYPE_VECTOR,
0,
sega_vh_start,
sega_vh_stop,
sega_vh_screenrefresh,
/* sound hardware */
0,0,0,0,
{
{
SOUND_SAMPLES,
&elim2_samples_interface
},
{
SOUND_CUSTOM, /* actually plays the samples */
&sega_custom_interface
}
}
};
static struct MachineDriver machine_driver_elim4 =
{
/* basic machine hardware */
{
{
CPU_Z80,
3867120, /* 3.86712 Mhz */
readmem,writemem,elim4_readport,elim_writeport,
0, 0, /* no vblank interrupt */
sega_interrupt, 40 /* 40 Hz */
}
},
40, 0, /* frames per second, vblank duration (vector game, so no vblank) */
1, /* single CPU, no need for interleaving */
0,
/* video hardware */
400, 300, { 512, 1536, 600, 1440 },
0,
256,256,
sega_init_colors,
VIDEO_TYPE_VECTOR,
0,
sega_vh_start,
sega_vh_stop,
sega_vh_screenrefresh,
/* sound hardware */
0,0,0,0,
{
{
SOUND_SAMPLES,
&elim2_samples_interface
},
{
SOUND_CUSTOM, /* actually plays the samples */
&sega_custom_interface
}
}
};
/***************************************************************************
Game driver(s)
***************************************************************************/
static const char *startrek_sample_names[] =
{
"*startrek",
/* Speech samples */
"st01.wav",
"st02.wav",
"st03.wav",
"st04.wav",
"st05.wav",
"st06.wav",
"st07.wav",
"st08.wav",
"st09.wav",
"st0a.wav",
"st0b.wav",
"st0c.wav",
"st0d.wav",
"st0e.wav",
"st0f.wav",
"st10.wav",
"st11.wav",
"st12.wav",
"st13.wav",
"st14.wav",
"st15.wav",
"st16.wav",
"st17.wav",
/* Sound samples */
"trek1.wav",
"trek2.wav",
"trek3.wav",
"trek4.wav",
"trek5.wav",
"trek6.wav",
"trek7.wav",
"trek8.wav",
"trek9.wav",
"trek10.wav",
"trek11.wav",
"trek12.wav",
"trek13.wav",
"trek14.wav",
"trek15.wav",
"trek16.wav",
"trek17.wav",
"trek18.wav",
"trek19.wav",
"trek20.wav",
"trek21.wav",
"trek22.wav",
"trek23.wav",
"trek24.wav",
"trek25.wav",
"trek26.wav",
"trek27.wav",
"trek28.wav",
0 /* end of array */
};
static struct Samplesinterface startrek_samples_interface =
{
10, /* 10 channels */
25, /* volume */
startrek_sample_names
};
static struct MachineDriver machine_driver_startrek =
{
/* basic machine hardware */
{
{
CPU_Z80,
3867120, /* 3.86712 Mhz */
readmem,writemem,zektor_readport,startrek_writeport,
0, 0, /* no vblank interrupt */
sega_interrupt, 40 /* 40 Hz */
}
},
40, 0, /* frames per second, vblank duration (vector game, so no vblank) */
1, /* single CPU, no need for interleaving */
0,
/* video hardware */
400, 300, { 512, 1536, 616, 1464 },
0,
256,256,
sega_init_colors,
VIDEO_TYPE_VECTOR,
0,
sega_vh_start,
sega_vh_stop,
sega_vh_screenrefresh,
/* sound hardware */
0,0,0,0,
{
{
SOUND_SAMPLES,
&startrek_samples_interface
},
{
SOUND_CUSTOM, /* actually plays the samples */
&sega_custom_interface
}
}
};
ROM_START( spacfury ) /* Revision C */
ROM_REGION( 0x10000, REGION_CPU1 ) /* 64k for code */
ROM_LOAD( "969c.u25", 0x0000, 0x0800, 0x411207f2 )
ROM_LOAD( "960c.u1", 0x0800, 0x0800, 0xd071ab7e )
ROM_LOAD( "961c.u2", 0x1000, 0x0800, 0xaebc7b97 )
ROM_LOAD( "962c.u3", 0x1800, 0x0800, 0xdbbba35e )
ROM_LOAD( "963c.u4", 0x2000, 0x0800, 0xd9e9eadc )
ROM_LOAD( "964c.u5", 0x2800, 0x0800, 0x7ed947b6 )
ROM_LOAD( "965c.u6", 0x3000, 0x0800, 0xd2443a22 )
ROM_LOAD( "966c.u7", 0x3800, 0x0800, 0x1985ccfc )
ROM_LOAD( "967c.u8", 0x4000, 0x0800, 0x330f0751 )
ROM_LOAD( "968c.u9", 0x4800, 0x0800, 0x8366eadb )
ROM_END
ROM_START( spacfura ) /* Revision A */
ROM_REGION( 0x10000, REGION_CPU1 ) /* 64k for code */
ROM_LOAD( "969a.u25", 0x0000, 0x0800, 0x896a615c )
ROM_LOAD( "960a.u1", 0x0800, 0x0800, 0xe1ea7964 )
ROM_LOAD( "961a.u2", 0x1000, 0x0800, 0xcdb04233 )
ROM_LOAD( "962a.u3", 0x1800, 0x0800, 0x5f03e632 )
ROM_LOAD( "963a.u4", 0x2000, 0x0800, 0x45a77b44 )
ROM_LOAD( "964a.u5", 0x2800, 0x0800, 0xba008f8b )
ROM_LOAD( "965a.u6", 0x3000, 0x0800, 0x78677d31 )
ROM_LOAD( "966a.u7", 0x3800, 0x0800, 0xa8a51105 )
ROM_LOAD( "967a.u8", 0x4000, 0x0800, 0xd60f667d )
ROM_LOAD( "968a.u9", 0x4800, 0x0800, 0xaea85b6a )
ROM_END
ROM_START( zektor )
ROM_REGION( 0x10000, REGION_CPU1 ) /* 64k for code */
ROM_LOAD( "1611.cpu", 0x0000, 0x0800, 0x6245aa23 )
ROM_LOAD( "1586.rom", 0x0800, 0x0800, 0xefeb4fb5 )
ROM_LOAD( "1587.rom", 0x1000, 0x0800, 0xdaa6c25c )
ROM_LOAD( "1588.rom", 0x1800, 0x0800, 0x62b67dde )
ROM_LOAD( "1589.rom", 0x2000, 0x0800, 0xc2db0ba4 )
ROM_LOAD( "1590.rom", 0x2800, 0x0800, 0x4d948414 )
ROM_LOAD( "1591.rom", 0x3000, 0x0800, 0xb0556a6c )
ROM_LOAD( "1592.rom", 0x3800, 0x0800, 0x750ecadf )
ROM_LOAD( "1593.rom", 0x4000, 0x0800, 0x34f8850f )
ROM_LOAD( "1594.rom", 0x4800, 0x0800, 0x52b22ab2 )
ROM_LOAD( "1595.rom", 0x5000, 0x0800, 0xa704d142 )
ROM_LOAD( "1596.rom", 0x5800, 0x0800, 0x6975e33d )
ROM_LOAD( "1597.rom", 0x6000, 0x0800, 0xd48ab5c2 )
ROM_LOAD( "1598.rom", 0x6800, 0x0800, 0xab54a94c )
ROM_LOAD( "1599.rom", 0x7000, 0x0800, 0xc9d4f3a5 )
ROM_LOAD( "1600.rom", 0x7800, 0x0800, 0x893b7dbc )
ROM_LOAD( "1601.rom", 0x8000, 0x0800, 0x867bdf4f )
ROM_LOAD( "1602.rom", 0x8800, 0x0800, 0xbd447623 )
ROM_LOAD( "1603.rom", 0x9000, 0x0800, 0x9f8f10e8 )
ROM_LOAD( "1604.rom", 0x9800, 0x0800, 0xad2f0f6c )
ROM_LOAD( "1605.rom", 0xa000, 0x0800, 0xe27d7144 )
ROM_LOAD( "1606.rom", 0xa800, 0x0800, 0x7965f636 )
ROM_END
ROM_START( tacscan )
ROM_REGION( 0x10000, REGION_CPU1 ) /* 64k for code */
ROM_LOAD( "1711a", 0x0000, 0x0800, 0x0da13158 )
ROM_LOAD( "1670c", 0x0800, 0x0800, 0x98de6fd5 )
ROM_LOAD( "1671a", 0x1000, 0x0800, 0xdc400074 )
ROM_LOAD( "1672a", 0x1800, 0x0800, 0x2caf6f7e )
ROM_LOAD( "1673a", 0x2000, 0x0800, 0x1495ce3d )
ROM_LOAD( "1674a", 0x2800, 0x0800, 0xab7fc5d9 )
ROM_LOAD( "1675a", 0x3000, 0x0800, 0xcf5e5016 )
ROM_LOAD( "1676a", 0x3800, 0x0800, 0xb61a3ab3 )
ROM_LOAD( "1677a", 0x4000, 0x0800, 0xbc0273b1 )
ROM_LOAD( "1678b", 0x4800, 0x0800, 0x7894da98 )
ROM_LOAD( "1679a", 0x5000, 0x0800, 0xdb865654 )
ROM_LOAD( "1680a", 0x5800, 0x0800, 0x2c2454de )
ROM_LOAD( "1681a", 0x6000, 0x0800, 0x77028885 )
ROM_LOAD( "1682a", 0x6800, 0x0800, 0xbabe5cf1 )
ROM_LOAD( "1683a", 0x7000, 0x0800, 0x1b98b618 )
ROM_LOAD( "1684a", 0x7800, 0x0800, 0xcb3ded3b )
ROM_LOAD( "1685a", 0x8000, 0x0800, 0x43016a79 )
ROM_LOAD( "1686a", 0x8800, 0x0800, 0xa4397772 )
ROM_LOAD( "1687a", 0x9000, 0x0800, 0x002f3bc4 )
ROM_LOAD( "1688a", 0x9800, 0x0800, 0x0326d87a )
ROM_LOAD( "1709a", 0xa000, 0x0800, 0xf35ed1ec )
ROM_LOAD( "1710a", 0xa800, 0x0800, 0x6203be22 )
ROM_END
ROM_START( elim2 )
ROM_REGION( 0x10000, REGION_CPU1 ) /* 64k for code */
ROM_LOAD( "cpu_u25.969", 0x0000, 0x0800, 0x411207f2 )
ROM_LOAD( "1333", 0x0800, 0x0800, 0xfd2a2916 )
ROM_LOAD( "1334", 0x1000, 0x0800, 0x79eb5548 )
ROM_LOAD( "1335", 0x1800, 0x0800, 0x3944972e )
ROM_LOAD( "1336", 0x2000, 0x0800, 0x852f7b4d )
ROM_LOAD( "1337", 0x2800, 0x0800, 0xcf932b08 )
ROM_LOAD( "1338", 0x3000, 0x0800, 0x99a3f3c9 )
ROM_LOAD( "1339", 0x3800, 0x0800, 0xd35f0fa3 )
ROM_LOAD( "1340", 0x4000, 0x0800, 0x8fd4da21 )
ROM_LOAD( "1341", 0x4800, 0x0800, 0x629c9a28 )
ROM_LOAD( "1342", 0x5000, 0x0800, 0x643df651 )
ROM_LOAD( "1343", 0x5800, 0x0800, 0xd29d70d2 )
ROM_LOAD( "1344", 0x6000, 0x0800, 0xc5e153a3 )
ROM_LOAD( "1345", 0x6800, 0x0800, 0x40597a92 )
ROM_END
ROM_START( elim2a )
ROM_REGION( 0x10000, REGION_CPU1 ) /* 64k for code */
ROM_LOAD( "cpu_u25.969", 0x0000, 0x0800, 0x411207f2 )
ROM_LOAD( "1158", 0x0800, 0x0800, 0xa40ac3a5 )
ROM_LOAD( "1159", 0x1000, 0x0800, 0xff100604 )
ROM_LOAD( "1160a", 0x1800, 0x0800, 0xebfe33bd )
ROM_LOAD( "1161a", 0x2000, 0x0800, 0x03d41db3 )
ROM_LOAD( "1162a", 0x2800, 0x0800, 0xf2c7ece3 )
ROM_LOAD( "1163a", 0x3000, 0x0800, 0x1fc58b00 )
ROM_LOAD( "1164a", 0x3800, 0x0800, 0xf37480d1 )
ROM_LOAD( "1165a", 0x4000, 0x0800, 0x328819f8 )
ROM_LOAD( "1166a", 0x4800, 0x0800, 0x1b8e8380 )
ROM_LOAD( "1167a", 0x5000, 0x0800, 0x16aa3156 )
ROM_LOAD( "1168a", 0x5800, 0x0800, 0x3c7c893a )
ROM_LOAD( "1169a", 0x6000, 0x0800, 0x5cee23b1 )
ROM_LOAD( "1170a", 0x6800, 0x0800, 0x8cdacd35 )
ROM_END
ROM_START( elim4 )
ROM_REGION( 0x10000, REGION_CPU1 ) /* 64k for code */
ROM_LOAD( "1390_cpu.u25", 0x0000, 0x0800, 0x97010c3e )
ROM_LOAD( "1347", 0x0800, 0x0800, 0x657d7320 )
ROM_LOAD( "1348", 0x1000, 0x0800, 0xb15fe578 )
ROM_LOAD( "1349", 0x1800, 0x0800, 0x0702b586 )
ROM_LOAD( "1350", 0x2000, 0x0800, 0x4168dd3b )
ROM_LOAD( "1351", 0x2800, 0x0800, 0xc950f24c )
ROM_LOAD( "1352", 0x3000, 0x0800, 0xdc8c91cc )
ROM_LOAD( "1353", 0x3800, 0x0800, 0x11eda631 )
ROM_LOAD( "1354", 0x4000, 0x0800, 0xb9dd6e7a )
ROM_LOAD( "1355", 0x4800, 0x0800, 0xc92c7237 )
ROM_LOAD( "1356", 0x5000, 0x0800, 0x889b98e3 )
ROM_LOAD( "1357", 0x5800, 0x0800, 0xd79248a5 )
ROM_LOAD( "1358", 0x6000, 0x0800, 0xc5dabc77 )
ROM_LOAD( "1359", 0x6800, 0x0800, 0x24c8e5d8 )
ROM_LOAD( "1360", 0x7000, 0x0800, 0x96d48238 )
ROM_END
ROM_START( startrek )
ROM_REGION( 0x10000, REGION_CPU1 ) /* 64k for code */
ROM_LOAD( "cpu1873", 0x0000, 0x0800, 0xbe46f5d9 )
ROM_LOAD( "1848", 0x0800, 0x0800, 0x65e3baf3 )
ROM_LOAD( "1849", 0x1000, 0x0800, 0x8169fd3d )
ROM_LOAD( "1850", 0x1800, 0x0800, 0x78fd68dc )
ROM_LOAD( "1851", 0x2000, 0x0800, 0x3f55ab86 )
ROM_LOAD( "1852", 0x2800, 0x0800, 0x2542ecfb )
ROM_LOAD( "1853", 0x3000, 0x0800, 0x75c2526a )
ROM_LOAD( "1854", 0x3800, 0x0800, 0x096d75d0 )
ROM_LOAD( "1855", 0x4000, 0x0800, 0xbc7b9a12 )
ROM_LOAD( "1856", 0x4800, 0x0800, 0xed9fe2fb )
ROM_LOAD( "1857", 0x5000, 0x0800, 0x28699d45 )
ROM_LOAD( "1858", 0x5800, 0x0800, 0x3a7593cb )
ROM_LOAD( "1859", 0x6000, 0x0800, 0x5b11886b )
ROM_LOAD( "1860", 0x6800, 0x0800, 0x62eb96e6 )
ROM_LOAD( "1861", 0x7000, 0x0800, 0x99852d1d )
ROM_LOAD( "1862", 0x7800, 0x0800, 0x76ce27b2 )
ROM_LOAD( "1863", 0x8000, 0x0800, 0xdd92d187 )
ROM_LOAD( "1864", 0x8800, 0x0800, 0xe37d3a1e )
ROM_LOAD( "1865", 0x9000, 0x0800, 0xb2ec8125 )
ROM_LOAD( "1866", 0x9800, 0x0800, 0x6f188354 )
ROM_LOAD( "1867", 0xa000, 0x0800, 0xb0a3eae8 )
ROM_LOAD( "1868", 0xa800, 0x0800, 0x8b4e2e07 )
ROM_LOAD( "1869", 0xb000, 0x0800, 0xe5663070 )
ROM_LOAD( "1870", 0xb800, 0x0800, 0x4340616d )
// I'm not sure where these roms are supposed to go, but they are speech
// related (from what I've read), so I just took a wild guess here,
// until their location is determined and speech is emulated, plus, it
// helps make sure everyone has them for the future... MRH
ROM_LOAD ("1670", 0xc000, 0x0800, 0xb779884b )
ROM_LOAD ("1871", 0xc800, 0x1000, 0x03713920 )
ROM_LOAD ("1872", 0xd800, 0x1000, 0xebb5c3a9 )
ROM_END
GAME( 1981, spacfury, 0, spacfury, spacfury, spacfury, ROT0, "Sega", "Space Fury (revision C)" )
GAME( 1981, spacfura, spacfury, spacfury, spacfury, spacfury, ROT0, "Sega", "Space Fury (revision A)" )
GAME( 1982, zektor, 0, zektor, zektor, zektor, ROT0, "Sega", "Zektor" )
GAME( 1982, tacscan, 0, tacscan, tacscan, tacscan, ROT270, "Sega", "Tac/Scan" )
GAME( 1981, elim2, 0, elim2, elim2, elim2, ROT0, "Gremlin", "Eliminator (2 Players, set 1)" )
GAME( 1981, elim2a, elim2, elim2, elim2, elim2, ROT0, "Gremlin", "Eliminator (2 Players, set 2)" )
GAME( 1981, elim4, elim2, elim4, elim4, elim4, ROT0, "Gremlin", "Eliminator (4 Players)" )
GAME( 1982, startrek, 0, startrek, startrek, startrek, ROT0, "Sega", "Star Trek" )